import Vue from "vue";

import "normalize.css/normalize.css"; // A modern alternative to CSS resets

import ElementUI from "element-ui";
import "element-ui/lib/theme-chalk/index.css";
// import locale from 'element-ui/lib/locale/lang/en' // lang i18n
// 导入自定义的语言包
import i18n from "@/lang";

import "@/styles/index.scss"; // global css

import App from "./App";
import store from "./store";
import router from "./router";

import "@/icons"; // icon
import "@/permission"; // permission control

import Print from "vue-print-nb"; // 打印插件
Vue.use(Print);

// 导入插件
import plugin from "@/utils/plugin";
// 导入定义的自定义指令
import * as alldir from "./directive/index.js"; // * 表示导入所有的，as取别名叫alldir
// 导入所有的过滤器
import * as allfilter from "./filter/index.js";
// console.log(alldir); //一个包含所有导入指令的对象
Object.keys(alldir).forEach(item => {
  Vue.directive(item, alldir[item]); // 通过遍历 挂载每一个自定义指令
});
// 注册过滤器
Object.keys(allfilter).forEach(item => {
  Vue.filter(item, allfilter[item]);
});

// 使用插件
Vue.use(plugin);

// set ElementUI lang to EN
// Vue.use(ElementUI, { locale })
// 如果想要中文版 element-ui，按如下方式声明
// Vue.use(ElementUI);
Vue.use(ElementUI, {
  i18n: (key, value) => i18n.t(key, value)
});

Vue.config.productionTip = false;

new Vue({
  el: "#app",
  router,
  store,
  i18n,
  render: h => h(App)
});
